home *** CD-ROM | disk | FTP | other *** search
-
- #include <windows.h>
- #include "sconopt.h"
- #include "sqlext.h"
-
-
- #if defined (WIN32)
- #define IS_WIN32 TRUE
- #else
- #define IS_WIN32 FALSE
- #endif
-
- #define IS_NT IS_WIN32 && (BOOL)(GetVersion() < 0x80000000)
- #define IS_WIN32S IS_WIN32 && (BOOL)(!(IS_NT) && (LOBYTE(LOWORD(GetVersion()))<4))
- #define IS_WIN95 (BOOL)(!(IS_NT) && !(IS_WIN32S)) && IS_WIN32
-
- HINSTANCE hInst; // current instance
-
- LPCTSTR lpszAppName = "MyApp";
- LPCTSTR lpszTitle = "SQLSetConnectOption()";
-
-
- BOOL RegisterWin95( CONST WNDCLASS* lpwc );
-
-
- int APIENTRY WinMain( HINSTANCE hInstance, HINSTANCE hPrevInstance,
- LPTSTR lpCmdLine, int nCmdShow)
- {
- MSG msg;
- HWND hWnd;
- WNDCLASS wc;
-
- wc.style = CS_HREDRAW | CS_VREDRAW;
- wc.lpfnWndProc = (WNDPROC)WndProc;
- wc.cbClsExtra = 0;
- wc.cbWndExtra = 0;
- wc.hInstance = hInstance;
- wc.hIcon = LoadIcon (hInstance, lpszAppName);
- wc.hCursor = LoadCursor(NULL, IDC_ARROW);
- wc.hbrBackground = (HBRUSH)(COLOR_WINDOW+1);
- wc.lpszMenuName = lpszAppName;
- wc.lpszClassName = lpszAppName;
-
- if ( IS_WIN95 )
- {
- if ( !RegisterWin95( &wc ) )
- return( FALSE );
- }
- else if ( !RegisterClass( &wc ) )
- return( FALSE );
-
- hInst = hInstance;
-
- hWnd = CreateWindow( lpszAppName,
- lpszTitle,
- WS_OVERLAPPEDWINDOW,
- CW_USEDEFAULT, 0,
- CW_USEDEFAULT, 0,
- NULL,
- NULL,
- hInstance,
- NULL
- );
-
- if ( !hWnd )
- return( FALSE );
-
- ShowWindow( hWnd, nCmdShow );
- UpdateWindow( hWnd );
-
- while( GetMessage( &msg, NULL, 0, 0) )
- {
- TranslateMessage( &msg );
- DispatchMessage( &msg );
- }
-
- return( msg.wParam );
- }
-
-
- BOOL RegisterWin95( CONST WNDCLASS* lpwc )
- {
- WNDCLASSEX wcex;
-
- wcex.style = lpwc->style;
- wcex.lpfnWndProc = lpwc->lpfnWndProc;
- wcex.cbClsExtra = lpwc->cbClsExtra;
- wcex.cbWndExtra = lpwc->cbWndExtra;
- wcex.hInstance = lpwc->hInstance;
- wcex.hIcon = lpwc->hIcon;
- wcex.hCursor = lpwc->hCursor;
- wcex.hbrBackground = lpwc->hbrBackground;
- wcex.lpszMenuName = lpwc->lpszMenuName;
- wcex.lpszClassName = lpwc->lpszClassName;
-
- // Added elements for Windows 95.
- //...............................
- wcex.cbSize = sizeof(WNDCLASSEX);
- wcex.hIconSm = LoadImage(wcex.hInstance, lpwc->lpszClassName,
- IMAGE_ICON, 16, 16,
- LR_DEFAULTCOLOR );
-
- return RegisterClassEx( &wcex );
- }
-
-
- LRESULT CALLBACK WndProc( HWND hWnd, UINT uMsg, WPARAM wParam, LPARAM lParam )
- {
- static HENV hEnv = NULL;
- static HDBC hDBC = NULL;
- static HWND hList = NULL;
-
- switch( uMsg )
- {
- case WM_CREATE :
- // Allocate Environment and Connection.
- //.....................................
- SQLAllocEnv( &hEnv );
- SQLAllocConnect( hEnv, &hDBC );
-
- hList = CreateWindow( "LISTBOX", "",
- LBS_NOTIFY | WS_VSCROLL |
- WS_BORDER | WS_CHILD |
- WS_VISIBLE | LBS_NOINTEGRALHEIGHT,
- 0, 0,
- 0, 0,
- hWnd,
- (HMENU)101,
- hInst,
- NULL
- );
-
- break;
-
- case WM_SIZE :
- MoveWindow( hList, 0, 0, LOWORD( lParam ),
- HIWORD( lParam ), TRUE );
- break;
-
- case WM_COMMAND :
- switch( LOWORD( wParam ) )
- {
- case IDM_TEST :
- {
- RETCODE retCode;
-
- // Connect to the data source
- //...........................
- retCode = SQLConnect( hDBC,
- "Test Data Source", SQL_NTS,
- NULL, 0,
- NULL, 0 );
-
- // Show connection status.
- //........................
- if( retCode == SQL_SUCCESS ||
- retCode == SQL_SUCCESS_WITH_INFO )
- {
- SendMessage( hList, LB_ADDSTRING,
- 0, (LPARAM)"Connection established." );
-
- retCode = SQLSetConnectOption( hDBC,
- SQL_AUTOCOMMIT, SQL_AUTOCOMMIT_OFF );
-
- if( retCode == SQL_SUCCESS ||
- retCode == SQL_SUCCESS_WITH_INFO )
- {
- SendMessage( hList, LB_ADDSTRING,
- 0, (LPARAM)"AutoCommit mode is now off.");
- }
- else
- {
- SendMessage( hList, LB_ADDSTRING,
- 0, (LPARAM)"SQLSetConnectOption() failed.");
- }
- }
- else
- {
- SendMessage( hList, LB_ADDSTRING,
- 0, (LPARAM)"Unable to establish connection" );
- }
- }
- break;
-
- case IDM_ABOUT :
- DialogBox( hInst, "AboutBox", hWnd, (DLGPROC)About );
- break;
-
- case IDM_EXIT :
- DestroyWindow( hWnd );
- break;
- }
- break;
-
- case WM_DESTROY :
- // Disconnect Environment.
- //........................
- if ( hDBC )
- SQLDisconnect( hDBC );
-
- // Free Connection and Environment.
- //.................................
- SQLFreeConnect( hDBC );
- SQLFreeEnv( hEnv );
-
- PostQuitMessage(0);
- break;
-
- default :
- return( DefWindowProc( hWnd, uMsg, wParam, lParam ) );
- }
-
- return( 0L );
- }
-
-
- LRESULT CALLBACK About( HWND hDlg,
- UINT message,
- WPARAM wParam,
- LPARAM lParam)
- {
- switch (message)
- {
- case WM_INITDIALOG:
- return (TRUE);
-
- case WM_COMMAND:
- if ( LOWORD(wParam) == IDOK
- || LOWORD(wParam) == IDCANCEL)
- {
- EndDialog(hDlg, TRUE);
- return (TRUE);
- }
- break;
- }
-
- return (FALSE);
- }
-